

# Gowin PicoRV32 Software Download **Reference Manual**

IPUG913-1.7E, 06/14/2024

#### Copyright © 2024 Guangdong Gowin Semiconductor Corporation. All Rights Reserved.

and GOWIN are trademarks of Guangdong Gowin Semiconductor Corporation and are registered in China, the U.S. Patent and Trademark Office, and other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders. No part of this document may be reproduced or transmitted in any form or by any means, electronic, mechanical, photocopying, recording or otherwise, without the prior written consent of GOWINSEMI.

#### Disclaimer

GOWINSEMI assumes no liability and provides no warranty (either expressed or implied) and is not responsible for any damage incurred to your hardware, software, data, or property resulting from usage of the materials or intellectual property except as outlined in the GOWINSEMI Terms and Conditions of Sale. GOWINSEMI may make changes to this document at any time without prior notice. Anyone relying on this documentation should contact GOWINSEMI for the current documentation and errata.

# **Revision History**

| Date       | Version | Description                                                                                                                                                                                                                                                                                                              |
|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 01/16/2020 | 1.0E    | Initial version published.                                                                                                                                                                                                                                                                                               |
| 03/06/2020 | 1.1E    | <ul> <li>MCU supports GPIO of Wishbone bus interface.</li> <li>MCU supports extension AHB bus interface.</li> <li>MCU supports off-chip SPI-Flash download and startup.</li> <li>MCU supports the read, write and erasure SPI-Flash.</li> <li>MCU supports Hardware Stack Protection and Trap Stack Overflow.</li> </ul> |
| 06/01/2020 | 1.2E    | <ul> <li>MCU on-line debug function supported.</li> <li>MCU core interrupt handler function enhanced.</li> <li>MCU core instruction optimized.</li> <li>Mergebin tool updated supports GowinSynthesis to parse the rules of naming.</li> </ul>                                                                           |
| 07/16/2021 | 1.3E    | <ul> <li>The synthesis tool SynplifyPro deleted.</li> <li>FPGA software version updated.</li> <li>Supported devices updated.</li> </ul>                                                                                                                                                                                  |
| 02/11/2022 | 1.4E    | The reference design of makehex and mergebin added.                                                                                                                                                                                                                                                                      |
| 08/18/2023 | 1.5E    | Arora V FPGA products supported.                                                                                                                                                                                                                                                                                         |
| 03/29/2024 | 1.6E    | mergebin tool updated to support GW2AN-18X/9X series of FPGA products.                                                                                                                                                                                                                                                   |
| 06/14/2024 | 1.7E    | mergebin tool updated to support Arora V FPGA products.                                                                                                                                                                                                                                                                  |

i

# **Contents**

IPUG913-1.7E

| C  | Contentsi                                                                                                                                                                                                                                                                                                                                                      |                                  |  |  |  |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--|--|--|
| Li | st of Figures                                                                                                                                                                                                                                                                                                                                                  | . iii                            |  |  |  |
| Li | st of Tables                                                                                                                                                                                                                                                                                                                                                   | . iv                             |  |  |  |
| 1  | Download Methods                                                                                                                                                                                                                                                                                                                                               | 1                                |  |  |  |
| 2  | Software Programming Output Used as ITCM Initialization Value                                                                                                                                                                                                                                                                                                  | 3                                |  |  |  |
|    | 2.1 Software Tools                                                                                                                                                                                                                                                                                                                                             | 3                                |  |  |  |
|    | 2.2 Command Parameters                                                                                                                                                                                                                                                                                                                                         | 3                                |  |  |  |
|    | 2.3 Hardware Configuration                                                                                                                                                                                                                                                                                                                                     | 3                                |  |  |  |
|    | 2.4 Software Configuration                                                                                                                                                                                                                                                                                                                                     | 4                                |  |  |  |
|    | 2.4.1 Boot Mode Configuration                                                                                                                                                                                                                                                                                                                                  | 4                                |  |  |  |
|    | 2.4.2 Flash linker Configuration                                                                                                                                                                                                                                                                                                                               | 4                                |  |  |  |
|    | 2.4.3 Output File Format Configuration                                                                                                                                                                                                                                                                                                                         | 5                                |  |  |  |
|    | 2.5 Design Flow                                                                                                                                                                                                                                                                                                                                                | 5                                |  |  |  |
|    | 2.6 Devices Supported                                                                                                                                                                                                                                                                                                                                          | 6                                |  |  |  |
|    | 2.7 Reference Design                                                                                                                                                                                                                                                                                                                                           | 6                                |  |  |  |
|    |                                                                                                                                                                                                                                                                                                                                                                |                                  |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design                                                                                                                                                                                                                                                                                                           | 7                                |  |  |  |
| 3  | -                                                                                                                                                                                                                                                                                                                                                              |                                  |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design                                                                                                                                                                                                                                                                                                           | 7                                |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design                                                                                                                                                                                                                                                                                                           | 7<br>7                           |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design                                                                                                                                                                                                                                                                                                           | 7<br>7<br>7                      |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design                                                                                                                                                                                                                                                                                                           | 7<br>7<br>7                      |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration                                                                                                                                                                                                         | 7<br>7<br>8<br>8                 |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.3.2 Post-Place File Configuration  3.4 Software Configuration  3.4.1 Boot Mode Configuration                                                                                                         | 7<br>7<br>8<br>8<br>9            |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.3.2 Post-Place File Configuration  3.4 Software Configuration  3.4.1 Boot Mode Configuration  3.4.2 Flash linker Configuration                                                                       | 7 7 8 8 9 9                      |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.3.2 Post-Place File Configuration  3.4 Software Configuration  3.4.1 Boot Mode Configuration                                                                                                         | 7 7 8 8 9 9                      |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.3.2 Post-Place File Configuration  3.4 Software Configuration  3.4.1 Boot Mode Configuration  3.4.2 Flash linker Configuration                                                                       | 7<br>7<br>8<br>8<br>9<br>9       |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.4.2 Post-Place File Configuration  3.4.1 Boot Mode Configuration  3.4.2 Flash linker Configuration  3.4.3 Output File Format Configuration  3.5 Design Flow  3.5.1 Merge                             | 7<br>7<br>8<br>9<br>9<br>9<br>10 |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design.  3.1 Software Tools.  3.2 Command Parameters.  3.3 Hardware Configuration.  3.3.1 ITCM Configuration.  3.4.2 Post-Place File Configuration.  3.4.1 Boot Mode Configuration.  3.4.2 Flash linker Configuration.  3.4.3 Output File Format Configuration.  3.5 Design Flow.  3.5.1 Merge.  3.5.2 Download. | 7 7 8 9 9 9 10 10 11             |  |  |  |
| 3  | Merge Results of Software Design and Hardware Design  3.1 Software Tools  3.2 Command Parameters  3.3 Hardware Configuration  3.3.1 ITCM Configuration  3.4.2 Post-Place File Configuration  3.4.1 Boot Mode Configuration  3.4.2 Flash linker Configuration  3.4.3 Output File Format Configuration  3.5 Design Flow  3.5.1 Merge                             | 7 7 8 9 9 9 10 10 11 11          |  |  |  |

| 4.1 Software Configuration                          | 12 |
|-----------------------------------------------------|----|
| 4.1.1 Boot Mode Configuration                       | 12 |
| 4.1.2 Flash Linker Configuration                    | 13 |
| 4.2 Hardware Configuration                          | 15 |
| 4.2.1 ITCM Configuration                            | 15 |
| 4.2.2 Dual-Purpose Pin Configuration                | 16 |
| 4.3 Design Flow                                     | 16 |
| 4.4 Download                                        | 17 |
| 4.4.1 Download Bitstream Files in Hardware Design   | 17 |
| 4.4.2 Download Software Programming Design BIN File | 19 |
| 4.5 Devices Supported                               | 21 |

# **List of Figures**

| Figure 2-1 Boot Mode and ITCM Initial Value Configuration           | 4  |
|---------------------------------------------------------------------|----|
| Figure 2-2 Boot Mode Configuration                                  | 4  |
| Figure 2-3 Flash Linker Configuration                               | 5  |
| Figure 3-1 ITCM Configuration                                       | 8  |
| Figure 3-2 Post-Place File Configuration                            | 9  |
| Figure 3-3 Boot Mode Configuration                                  | 9  |
| Figure 3-4 Flash Linker Configuration                               | 10 |
| Figure 3-5 Merge the Outputs of Software Design and Hardware Design | 11 |
| Figure 4-1 Boot MODE "BUILD_BURN" Configuration                     | 12 |
| Figure 4-2 Boot MODE "BUILD_XIP" Configuration                      | 13 |
| Figure 4-3 Flash Linker Configuration                               | 14 |
| Figure 4-4 Flash Linker Configuration                               | 15 |
| Figure 4-5 ITCM Configuration                                       | 16 |
| Figure 4-6 Dual-Purpose Pin Configuration                           | 16 |
| Figure 4-7 Device configuration for Arora Family                    | 18 |
| Figure 4-8 Device Configuration for Arora V                         | 19 |
| Figure 4-9 Device configuration for Arora Family                    | 20 |
| Figure 4-10 Device configuration for Arora V                        | 21 |

IPUG913-1.7E iii

# **List of Tables**

| Table 3-1 mergebin Commands and Parameters | 7 |
|--------------------------------------------|---|
|                                            |   |

IPUG913-1.7E iv

# **1** Download Methods

Gowin\_PicoRV32 provides three download methods of hardware design and software programming design:

- 1. Use executable program file generated by software programming design as the initial value of ITCM, the instruction memory, in hardware design.
  - a) Gowin PicoRV32 software programming design:
    - Define the macro definition of config.h as #define BUILD MODE BUILD LOAD
    - Select sections.lds as FLASH linker
    - Build to generate software programming design BIN files
  - b) Use makehex tool to convert the software programming design BIN files to ram32.hex.
  - c) Configure ITCM, the instruction memory, where IP Core Generator generates Gowin PicoRV32 design.
    - Select "MCU boot and run in ITCM" in Boot Mode.
    - ITCM Initialiaztion File import ram32.hex file in b) as the initial value of ITCM.
  - d) Synthesis, place & route to generate the bitstream files in hardware design including software programming design and hardware design.
  - e) Use Programmer to download bitstream files in hardware design.
  - f) After each update of the software programming design, rerun a) ~
     e).
- 2. Merge the software programming design BIN files generated by software programming design and the BIN files in hardware design generated by hardware design.
  - a) Generate the Gowin\_PicoRV32 bitstream files and Post-Place File in hardware design according to the application requirements in accordance with Method 1. If there is no hardware update requirement, the fixed bitstream files in hardware design will not be

IPUG913-1.7E 1(21)

updated.

- b) Update Gowin PicoRV32 software programming design:
  - Define the macro definition of config.h as #define BUILD\_MODE BUILD\_LOAD
  - Configure sections.lds as FLASH linker
  - Update user application design according to the application requirements
  - Build to generate software programming design BIN files
- a) Use merge-bit tool to merge the software programming design BIN files and bitstream files in hardware design in a).
- b) Generate new bitstream files in hardware design after merging the software design and the hardware design.
- c) Use Programmer to download the new bitstream files in hardware design after merging.
- d) After each update of the software programming design, rerun b) ~e).
- 3. Use off-chip SPI-Flash memory to download the BIN files generated by software programming design.
  - a) Configure ITCM, the instruction memory, where IP Core Generator generates Gowin\_PicoRV32 design.
    - Select "MCU boot and run in external Flash" or "MCU boot from external Flash and run in ITCM" in Boot Mode
  - b) Gowin\_PicoRV32 hardware design generates bitstream files in hardware design with the function of off-chip SPI-Flash downloading and startup.
  - c) Use Programmer to download bitstream files in hardware design.
  - d) Gowin PicoRV32 software programming design:
    - MCU boot and run in external Flash
       Define the macro definition of config.h as #define
       BUILD\_MODE BUILD\_XIP
       Select sections xip.lds as FLASH linker
    - MCU boot from external Flash and run in ITCM
      Define the macro definition of config.h as #define
      BUILD\_MODE BUILD\_BURN
      Select sections.lds as FLASH linker
    - Build to generate software programming design BIN files.
  - e) Use Programmer to download the BIN files generated by software programming design.

IPUG913-1.7E 2(21)

# 2 Software Programming Output Used as ITCM Initialization Value

#### 2.1 Software Tools

- ...\tool\makehex\bin\makehex32.exe
- ...\tool\makehex\bin\makehex08.exe

Access the above software tools through the following link: <a href="mailto:cdn.gowinsemi.com.cn/Gowin">cdn.gowinsemi.com.cn/Gowin</a> PicoRV32.zip

#### 2.2 Command Parameters

Software tool command and parameter: make hex.exe bin-file

# 2.3 Hardware Configuration

Double click to open ITCM configuration options when configuring Gowin\_PicoRV32 in IP Core Generator tool integrated in Gowin Software:

Select "ITCM > Boot Mode > MCU boot and run in ITCM" option.

Import ram32.hex file generated by make\_hex tool as the initial value of ITCM in "ITCM Initialization File", as shown in Figure 2-1.

IPUG913-1.7E 3(21)



Figure 2-1 Boot Mode and ITCM Initial Value Configuration

# 2.4 Software Configuration

#### 2.4.1 Boot Mode Configuration

Define the macro definition of config.h as #define BUILD\_MODE BUILD LOAD, as shown in Figure 2-2.

Figure 2-2 Boot Mode Configuration

### 2.4.2 Flash linker Configuration

In the "Project Explorer" view of GMD software, select the current software project, right-click and select "Properties > C/C++ Build > Settings > Tool Settings > GNU RISC-V Cross C Linker > General", select "sections.lds" as the Flash linker, as shown in Figure 2-3.

IPUG913-1.7E 4(21)



Figure 2-3 Flash Linker Configuration

## 2.4.3 Output File Format Configuration

Compile Gowin\_PicoRV32 software programming design and generate software programming design BIN files.

Run make\_hex.exe bin-file command to generate ram32.hex.

## 2.5 Design Flow

- 1. Software programming design flow is as follows:
  - The definition of config.h: #define BUILD MODE BUILD LOAD
  - Select section.lds as FLASH linker
  - Build to generate software programming design BIN files
  - Run make\_hex.exe to generate ram32.hex as the initial value of ITCM in Gowin PicoRV32 IP design
- 2. Hardware design flow is as follows:
  - Select "ITCM > Boot Mode > MCU boot and run in ITCM" option
  - Import ram32.hex file as the initial value of ITCM in "ITCM Initialization File"
- 3. Generate Gowin\_PicoRV32 IP design, instantiate Gowin\_PicoRV32 Top Module, and connect user design
- 4. Add physical and timing Constraints

IPUG913-1.7E 5(21)

- 5. Use GowinSynthesis to synthesize and generate the netlist file
- 6. Run Place & Route tool to generate the bitstream files containing software programming design
- 7. Use Programmer to download
- 8. After each update of the software programming design, rerun 1~7

# 2.6 Devices Supported

- LittleBee Family FPGA products
- Arora Family FPGA products
- Arora V FPGA products

# 2.7 Reference Design

You can get the following reference design through the link:

...\tool\make\_hex\ref\_design\FPGA\_RefDesign\gowin\_picorv32

...\tool\make\_hex\ref\_design\MCU\_RefDesign\picorv32\_demo

IPUG913-1.7E 6(21)

# 3 Merge Results of Software Design and Hardware Design

#### 3.1 Software Tools

...\tool\merge\_bit\bin\merge\_bit.exe

Access the above software tools through the following link: cdn.gowinsemi.com.cn/Gowin PicoRV32.zip

#### 3.2 Command Parameters

Software tool command parameter: merge\_bit.exe bin-file fs-file itcm\_size posp-file.

The descriptions of command parameters are as shown in Table 3-1.

**Table 3-1 Command Parameter** 

| Parameter | Description                                                                       |
|-----------|-----------------------------------------------------------------------------------|
| posp-file | Post-Place File                                                                   |
| itcm-size | ITCM Size (KB) For example, if ITCM Size is set as 64K Byte, the parameter is 64. |
| bin-file  | Software programming design BIN file                                              |
| fs-file   | Bitstream files in hardware design                                                |

Merge the software programming design BIN files generated by software programming design and the bitstream files in hardware design generated by hardware design.

When merge\_bit.bat is in use, you can modify the parameters, such as posp-file, itcm-size, bin-file, and fs-file according to your requirements.

# 3.3 Hardware Configuration

Generate the Gowin\_PicoRV32 IP design according to Method 1 described in Chapter <u>2 Software Programming Output Used as ITCM</u> <u>Initialization Value</u>, synthesize, place and route to generate the bitstream files and Post-Place File in hardware design. If there is no hardware update

IPUG913-1.7E 7(21)

requirement, the fixed bitstream files in hardware design will not be updated.

After each update of the software programming design, simply use the merge\_bit tool each time to merge the bitstream files in hardware design mentioned above with the software programming design BIN files for each update.

#### 3.3.1 ITCM Configuration

Double click to open ITCM configuration options when configuring Gowin PicoRV32 in IP Core Generator tool integrated in Gowin Software:

- Select "ITCM > Boot Mode > MCU boot and run in ITCM" option
- Import ram32.hex file as the initial value of ITCM in "ITCM Initialization File", as shown in Figure 3-1.

Figure 3-1 ITCM Configuration



### 3.3.2 Post-Place File Configuration

A Post-Place file, as the posp-file, will be generated when the value in "Place & Route > General > Generate Post-Place File" is set to "True", as shown in Figure 3-2.

IPUG913-1.7E 8(21)



Figure 3-2 Post-Place File Configuration

# 3.4 Software Configuration

#### 3.4.1 Boot Mode Configuration

Configure the macro definition of config.h as #define BUILD\_MODE BUILD\_LOAD, as shown in Figure 3-3.

Figure 3-3 Boot Mode Configuration

```
li config.h ⊠
      * @file
* @author
* @device
                            GowinSemicoducto
Gowin_PicoRV32
       * @brief Configurations
 10 #ifndef CONFIG_H_
      #define CONFIG_H
       //User configures MCU boot mode
        * BUILD_LOAD : MCU boot from and run in ITCM
                             sections.lds
      * BUILD_BURN: MCU boot from external flash and run in ITCM

* sections.lds
       * BUILD_XIP : MCU boot from and run in external flash
                              sections_xip.lds
 22
      #define BUILD_LOAD 0 // MCU boot from and run in ITCM, must use sections.lds as linker script!
#define BUILD_BURN 1 // MCU boot from external flash and run in ITCM, must use sections.lds as linker script!
#define BUILD_XIP 2 // MCU boot from and run in external flash, must use sections_xip.lds as linker script!
       #define BUILD_MODE BUILD_LOAD //must match with hardware IP
        * sections_debug.lds is for debug.
```

### 3.4.2 Flash linker Configuration

In the "Project Explorer" view of GMD software, select the current software project, right-click and select "Properties > C/C++ Build > Settings > Tool Settings > GNU RISC-V Cross C Linker > General", select sections.lds as the Flash linker, as shown in Figure 3-4.

IPUG913-1.7E 9(21)



Figure 3-4 Flash Linker Configuration

#### 3.4.3 Output File Format Configuration

Compile Gowin\_PicoRV32 software programming design and generate software programming design BIN files.

# 3.5 Design Flow

### **3.5.1** Merge

- Generate the Gowin\_PicoRV32 bitstream files and Post-Place File in hardware design according to the application requirements in accordance with Method 1 described in Chapter <u>2 Software</u> <u>Programming Output Used as ITCM Initialization Value</u>. If there is no hardware update requirement, the fixed bitstream files in hardware design will not be updated.
- 2. Update Gowin PicoRV32 software programming design:
  - Define the macro definition of config.h as #define BUILD\_MODE BUILD\_LOAD
  - Select sections.lds as FLASH linker
  - Update user application design according to the application requirements
  - Build to generate software programming design BIN files
- 3. Modify merge\_bit.bat according to the actual application, and perform

IPUG913-1.7E 10(21)

merge\_bit.bat, merge the bitstream files in hardware design generated by hardware design and the software programming design BIN files generated by software programming design to generate new bitstream files, as shown in Figure 3-5.

4. After each update of the software programming design, re-run step 3~4

Figure 3-5 Merge the Outputs of Software Design and Hardware Design

#### 3.5.2 Download

After merging, use Programmer, the download tool, to download the new bitstream files in hardware design.

For the usage of Gowin Programmer, please see <u>SUG502, Gowin</u> Programmer User Guide.

# 3.6 Devices Supported

- LittleBee Family FPGA products
- Arora Family FPGA products
- Arora V FPGA products

# 3.7 Reference Design

You can get the following reference design through the <u>link</u>:

...\tool\merge\_bit\ref\_design\FPGA\_RefDesign\gowin\_picorv32

...\tool\merge\_bit\ref\_design\MCU\_RefDesign\picorv32\_demo

IPUG913-1.7E 11(21)

# 4 Off-chip SPI-Flash Memory Download

# 4.1 Software Configuration

#### 4.1.1 Boot Mode Configuration

If "ITCM > Boot Mode > MCU boot from external Flash and run in ITCM" is selected in Gowin\_PicoRV32 IP design, then config.h is defined as #define BUILD\_MODE BUILD\_BURN in Gowin\_PicoRV32 software programming design config.h, as shown in Figure 4-1.

Figure 4-1 Boot MODE "BUILD\_BURN" Configuration

If the "ITCM > Boot Mode > MCU boot and run in external Flash" is selected in Gowin\_PicoRV32 IP design, then config.h is defined as #define BUILD\_MODE BUILD\_XIP in Gowin\_PicoRV32 software programming design config.h, as shown in Figure 4-2.

IPUG913-1.7E 12(21)

Figure 4-2 Boot MODE "BUILD\_XIP" Configuration

### 4.1.2 Flash Linker Configuration

If "ITCM > Boot Mode > MCU boot from external Flash and run in ITCM" is selected in the Gowin\_PicoRV32 IP design, then the current software project is selected in the "Project Explorer" view of the GMD software; right-click and select "Properties > C/C++ Build > Settings > Tool Settings > GNU RISC-V Cross C Linker > General", then select "Selections.lds" as the Flash linker, as shown in Figure 4-3.

For example, "\${workspace loc:/\${ProjName}/src/sections.lds}".

IPUG913-1.7E 13(21)



Figure 4-3 Flash Linker Configuration

If "ITCM > Boot Mode > MCU boot and run in external Flash" is selected in the Gowin\_PicoRV32 IP design, then the current software project is selected in the "Project Explorer" view of the GMD software; right-click and select "Properties > C/C++ Build > Settings > Tool Settings > GNU RISC-V Cross C Linker > General", then select "sections\_xip.lds" as the Flash linker, as shown in Figure 4-4.

For example, "\${workspace\_loc:/\${ProjName}/src/sections\_xip.lds}".

IPUG913-1.7E 14(21)



Figure 4-4 Flash Linker Configuration

# 4.2 Hardware Configuration

#### 4.2.1 ITCM Configuration

Select the "ITCM > Boot Mode > MCU Boots from External Flash and Runs in ITCM" or "MCU Boots from External Flash and Runs in External Flash" option in the IP Core Generator tool of Gowin Software, as shown in Figure 4-5.

IPUG913-1.7E 15(21)

♣ ITCM **ITCM** Gowin\_PicoRV32 is intended for deeply embedded applications that is integrated into Gowin FPGA, which is based on RISC-V 32Bit ISA RV32IMC. ITCM is the instruction memory of this MCU. Its size is configurable. If the MCU boot mode is set as boot and run in ITCM, the ITCM should be initialized and the initialization file should be set. Options Configuration ITCM Size: 32KB Boot Mode: MCU boot from external Flash and run in ITCM O MCU boot and run in external Flash O MCU boot and run in ITCM Gowin PicoRV32 Cancel

Figure 4-5 ITCM Configuration

# 4.2.2 Dual-Purpose Pin Configuration

Configure dedicated IO as regular IO under "Place & Route > Dual-Purpose Pin" option, such as MSPI and CPU, as shown in Figure 4-6.

Figure 4-6 Dual-Purpose Pin Configuration



# 4.3 Design Flow

- Hardware Design Flow:
  - Select "Boot Mode > MCU boot from external Flash and run in ITCM" or "MCU boot and run in external Flash"
  - Generate Gowin\_PicoRV32 IP design

IPUG913-1.7E 16(21)

- Synthesis, place & route to generate the bitstream files with off-chip SPI-Flash memory download function
- 2. Configure Device configuration with Programmer to download the bitstream files in hardware design.
- 3. Gowin PicoRV32 software programming design:
  - MCU boot and run in external Flash:

Define the macro definition of config.h as #define BUILD\_MODE BUILD XIP

Select sections\_xip.lds as FLASH linker

- MCU boot from external Flash and run in ITCM
   Define the macro definition of config.h as #define BUILD\_MODE
   BUILD\_BURN
  - Select sections.lds as FLASH linker
- Build to generate software programming design BIN files
- 4. Configure Device configuration with Programmer to download the software programming design BIN files.

#### 4.4 Download

For the usage of Gowin Programmer, please see <u>SUG502, Gowin</u> Programmer User Guide.

#### 4.4.1 Download Bitstream Files in Hardware Design

Gowin\_PicoRV32 hardware design generates bitstream files with the function of off-chip SPI-Flash downloading and startup. Use the download tool Programmer to download the hardware design bitstream file.

Click "Tools > Programmer" on the menu bar or "Programmer" ( ) on the tool bar to open the "Device configuration".

If the development board has a Arora Family FPGA product on board, the download configuration option is as shown in Figure 4-7.

- Select "External Flash Mode" in "Access Mode" drop-down list.
- Select "exFlash Erase, Program thru GAO-Bridge" or "exFlash Erase, Program, Verify thru GAO-Bridge" in "Operation" drop-down list.
- Import the hardware design bitstream file that is required to download in "Programming Options > File name" option.
- Select "Generic Flash" from "External Flash Options > Device" option.
- Set "0x000000" in "External Flash Options > Start Address" option.
   Click "Save", as shown in Figure 4-7.

IPUG913-1.7E 17(21)



Figure 4-7 Device configuration for Arora Family

If the development board has a Arora V FPGA product on board, the download configuration option is as shown in Figure 4-8.

- Select "External Flash Mode 5AT" in "Access Mode" drop-down list.
- Select "exFlash Erase, Program 5AT" or "exFlash Erase, Program, Verify 5AT" in "Operation" drop-down list.
- Import the hardware design bitstream file that is required to download in "Programming Options > File name" option.
- Select "Generic Flash" from "External Flash Options > Device" option.
- Set "0x000000" in "External Flash Options > Start Address" option.
   Click "Save" to complete the configuration, as shown in Figure 4-8.

IPUG913-1.7E 18(21)



Figure 4-8 Device Configuration for Arora V

After device configuration, click "Program/Configure" ( ) in the Programmer toolbar to complete the downloading of bitstream files in hardware design.

#### 4.4.2 Download Software Programming Design BIN File

After Gowin\_PicoRV32 software programming design, generate software programming design BIN files, and use Programmer to download Gowin\_PicoRV32 software programming design BIN files.

In GMD software, click "Run>Programmer" on the menu bar or "Programmer" (III) on the tool bar to open Programmer.

Click "Edit > Configure Device" on the menu bar or "Configure Device" () on the tool bar to open the "Device configuration".

If the development board has a Arora Family FPGA product on board, the download configuration option is as shown in Figure 4-9.

- Select "External Flash Mode" in "Access Mode" drop-down list.
- Select "exFlash C Bin Erase, Program thru GAO-Bridge" or "exFlash C Bin Erase, Program, Verify thru GAO-Bridge" in "Operation" drop-down list.
- Select "FW/MCU Input Options > Firmware/Binary File" to import the software programming design BIN files that are required to download.
- Select "Generic Flash" from "External Flash Options > Device" option.
- Set "0x400000" in "External Flash Options > Start Address" option.
   Click "Save" to complete the configuration, as shown in Figure 4-9.

IPUG913-1.7E 19(21)



Figure 4-9 Device configuration for Arora Family

If the development board has a Arora V FPGA product on board, the download configuration option is as shown in Figure 4-10.

- Select "External Flash Mode 5AT" in "Access Mode" drop-down list.
- Select "exFlash C Bin Erase, Program 5AT" or "exFlash Erase, Program, Verify 5AT" in "Operation" drop-down list.
- Import the hardware design bitstream file that is required to download in "FW/MCU/Binary Input Options > Firmware/Binary File" option.
- Select "Generic Flash" from "External Flash Options > Device" option.
- In "External Flash Options > Start Address" option, according to different Arora V FPGA products, you can set the address to "0x600000" (138K, 75K products), "0x400000" (60K products), "0x100000" (25K and 15K products).

Click "Save" to complete the configuration, as shown in Figure 4-10.

IPUG913-1.7E 20(21)



Figure 4-10 Device configuration for Arora V

After device configuration, click "Program/Configure" ( ) on the Programmer tool bar to complete the downloading of software programming design BIN files.

# 4.5 Devices Supported

- Arora Family FPGA products
- Arora V FPGA products

IPUG913-1.7E 21(21)

